<!DOCTYPE html>
<html lang="zh" xmlns:th="http://www.thymeleaf.org" xmlns:shiro="http://www.pollix.at/thymeleaf/shiro">
<head>
    <th:block th:include="include :: header('compare列表')"/>
    <style>
        td, th {
            white-space: nowrap;
        }
    </style>
</head>
<body class="gray-bg">
<div class="container-div">
    <div class="row">
        <div class="col-sm-12 search-collapse">
            <form id="formId">
                <div class="select-list">
                    <ul>
                        <li>
                            <p>名称：</p>
                            <input type="text" name="name"/>
                        </li>
                        <li>
                            <a class="btn btn-primary btn-rounded btn-sm" onclick="$.table.search()"><i
                                    class="fa fa-search"></i>&nbsp;搜索</a>
                            <a class="btn btn-warning btn-rounded btn-sm" onclick="$.form.reset()"><i
                                    class="fa fa-refresh"></i>&nbsp;重置</a>
                        </li>
                    </ul>
                </div>
            </form>
        </div>

        <div class="btn-group-sm" id="toolbar" role="group">
            <a class="btn btn-success" onclick="$.operate.add()" shiro:hasPermission="bus:compare:add">
                <i class="fa fa-plus"></i> 添加
            </a>
            <a class="btn btn-primary single disabled" onclick="$.operate.edit()"
               shiro:hasPermission="bus:compare:edit">
                <i class="fa fa-edit"></i> 修改
            </a>
            <a class="btn btn-danger multiple disabled" onclick="$.operate.removeAll()"
               shiro:hasPermission="bus:compare:remove">
                <i class="fa fa-remove"></i> 删除
            </a>
            <a class="btn btn-warning" onclick="$.table.exportExcel()" shiro:hasPermission="bus:compare:export">
                <i class="fa fa-download"></i> 导出
            </a>
        </div>
        <div class="col-sm-12 select-table table-striped">
            <table id="bootstrap-table"></table>
        </div>
    </div>
</div>
<th:block th:include="include :: footer"/>
<script th:inline="javascript">
    var editFlag = [[${@permission.hasPermi('bus:compare:edit')}]];
    var removeFlag = [[${@permission.hasPermi('bus:compare:remove')}]];
    var prefix = ctx + "bus/compare";

    $(function () {
        var options = {
            url: prefix + "/list",
            createUrl: prefix + "/add",
            updateUrl: prefix + "/edit/{id}",
            removeUrl: prefix + "/remove",
            exportUrl: prefix + "/export",
            modalName: "比对规则",
            columns: [{
                checkbox: true
            },
                {
                    field: 'id',
                    title: '主键',
                    visible: false
                },
                {
                    field: 'name',
                    title: '名称'
                },
                {
                    field: 'describe',
                    title: '描述'
                },
                {
                    field: 'ruleColumns',
                    title: '比对字段',
                    formatter: function (value, row, index) {
                        var columns = jsonParse(value);
                        if (columns instanceof Array && columns.length > 0) {
                            var res = "";
                            $.each(columns, function (index, item) {
                                res += item['label'] + "<br />";
                            });
                            return res;
                        }
                        return "无";
                    }
                },
                {
                    field: 'ruleTables',
                    title: '比对表',
                    formatter: function (value, row, index) {
                        var columns = jsonParse(value);
                        if (columns instanceof Array && columns.length > 0) {
                            var res = "";
                            $.each(columns, function (index, item) {
                                res += item['label'] + "<br />";
                            });
                            return res;
                        }
                        return "无";
                    }
                },
                {
                    field: 'showType',
                    title: '数据显示类型',
                    formatter: function (value, row, index) {
                        console.log(value);
                        return value == '0' ? '显示相同数据' : "显示不同数据";
                    }
                },
                {
                    title: '操作',
                    align: 'center',
                    formatter: function (value, row, index) {
                        var actions = [];
                        actions.push('<a class="btn btn-success btn-xs ' + editFlag + '" href="javascript:void(0)" onclick="$.operate.edit(\'' + row.id + '\')"><i class="fa fa-edit"></i>编辑</a> ');
                        actions.push('<a class="btn btn-danger btn-xs ' + removeFlag + '" href="javascript:void(0)" onclick="$.operate.remove(\'' + row.id + '\')"><i class="fa fa-remove"></i>删除</a>');
                        actions.push('<a class="btn btn-default btn-xs" style="margin-left: 5px;" href="javascript:void(0)" onclick="startCompare(\'' + row.id + '\')"><i class="fa fa-paper-plane"></i>开始比对</a>');
                        return actions.join('');
                    }
                }]
        };
        $.table.init(options);
    });

    function startCompare(id) {
        var height = ($(window).height() - 50);
        layer.open({
            type: 2,
            area: ['800px', height + 'px'],
            fix: false,
            //不固定
            maxmin: true,
            shade: 0.3,
            title: "比对数据显示",
            content: prefix + "/compareData?id=" + id,
            btn: ['导出', '关闭'],
            // 弹层外区域关闭
            shadeClose: true,
            yes: function (index, layero) {
                console.log(index, layero);
                layer.close(index);
                $.modal.confirm("确定导出所有比对数据吗？", function() {
                    $.modal.loading("正在导出数据，请稍后...");
                    $.post(prefix + "/exportCompareData", {id: id}, function(result) {
                        if (result.code == web_status.SUCCESS) {
                            window.location.href = ctx + "common/download?fileName=" + encodeURI(result.msg) + "&delete=" + true;
                        } else if (result.code == web_status.WARNING) {
                            $.modal.alertWarning(result.msg)
                        } else {
                            $.modal.alertError(result.msg);
                        }
                        $.modal.closeLoading();
                    });
                });
            },
            cancel: function(index) {
                return true;
            }
        });
    }

    function jsonParse(str) {
        try {
            return JSON.parse(str);
        } catch (e) {
            return JSON.parse(JSON.stringify(str));
        }
    }
</script>
</body>
</html>